// eslint-disable-next-line no-undef
const db = require('../db/index.js')

// eslint-disable-next-line no-undef
const bcrypt = require('bcryptjs')

// 获取用户基本信息的处理函数
// eslint-disable-next-line no-undef
exports.getUserInfo = (req, res) => {
  const sql = `select id,username,nickname,email,user_pic from ev_users where id=?`
  db.query(sql, req.body.id, (err, results) => {
    if (err) {
      return res.cc(err)
    }

    if (results.length !== 1) return res.cc('获取用户信息失败！')

    res.send({
      status: 0,
      message: '获取用户基本信息成功',
      data: results[0]
    })
  })
}

// 更新用户的基本信息
// eslint-disable-next-line no-undef
exports.updateUserInfo = (req, res) => {
  const sql = `update ev_users set ? where id = ?`

  console.log('sql=》', req.body)

  db.query(sql, [req.body, req.body.id], (err, results) => {
    if (err) return res.cc(err)

    if (results.affectedRows !== 1) return res.cc('修改用户基本信息失败')

    return res.cc('修改用户基本信息成功！', 0)
  })
}

// 重置密码
// eslint-disable-next-line no-undef
exports.updatePassword = (req, res) => {
  const sql = `select * from ev_users where id = ?`

  db.query(sql, req.user.id, (err, results) => {
    if (err) return res.cc(err)

    if (results.length !== 1) return res.cc('用户不存在！')

    const compareResult = bcrypt.compareSync(req.body.oldPwd, results[0].password)
    if (!compareResult) return res.cc('原密码错误！')

    const sql = `update ev_users set password=? where id=?`
    const newPwd = bcrypt.hashSync(req.body.newPwd, 10)

    db.query(sql, [newPwd, req.user.id], (err, results) => {
      if (err) return res.cc(err)
      // SQL 语句执行成功，但是影响行数不等于 1
      if (results.affectedRows !== 1) return res.cc('更新密码失败！')

      // 更新密码成功
      res.cc('更新密码成功！', 0)
    })
  })
}

// 更新用户头像
// eslint-disable-next-line no-undef
exports.updateAvatar = (req, res) => {
  const sql = 'update ev_users set user_pic=? where id=?'
  db.query(sql, [req.body.avatar, req.user.id], (err, results) => {
    // 执行 SQL 语句失败
    if (err) return res.cc(err)

    // 执行 SQL 语句成功，但是影响行数不等于 1
    if (results.affectedRows !== 1) return res.cc('更新头像失败！')

    // 更新用户头像成功
    return res.cc('更新头像成功！', 0)
  })
}
